<template>
	<view class="container">
		<view class="main">
			<view v-if="!addresses.length" class="no-address-tips">
				<view class="mb-30">暂无地址信息</view>
				<view>请点击底部按钮添加地址信息</view>
			</view>
			<template v-else>
				<uni-swipe-action>
					<uni-swipe-action-item class="address-wrapper" :options="swipeOption" @click="handleSwipeClick(address.id)" v-for="(address, index) in addresses"
					 :key="index">
						<view class="address" @tap="chooseAddress(address)">
							<view class="left flex-fill overflow-hidden mr-20">
								<view class="font-size-lg font-weight-bold text-truncate" style="margin-bottom: 10rpx;">
									<view class="default" v-if="address.isDefault == 1">默认</view>
									{{ `${address.provinceName}${address.cityName}${address.areaName}${address.communityName ? address.communityName : ''}${address.address}` }}
								</view>
								<view class="font-size-sm text-color-assist">{{ address.consignee }} {{ address.mobile }}</view>
							</view>
							<image src="/static/images/edit.png" class="edit-icon" @tap.stop="edit(address.id)"></image>
						</view>
					</uni-swipe-action-item>
				</uni-swipe-action>
			</template>
		</view>
		<view class="btn-box"><button type="primary" size="default" @tap="add">新增地址</button></view>
	</view>
</template>

<script>
	import {
		mapGetters,
		mapMutations,
		mapActions
	} from 'vuex';
	import uniSwipeAction from '@/components/uni-swipe-action/uni-swipe-action';
	import uniSwipeActionItem from '@/components/uni-swipe-action-item/uni-swipe-action-item';

	export default {
		components: {
			uniSwipeAction,
			uniSwipeActionItem
		},
		data() {
			return {
				scene: 'menu',
				is_choose: false, //是否选择地址
				swipeOption: [{
					text: '删除',
					style: {
						backgroundColor: '#D12E32'
					}
				}]
			};
		},
		computed: {
			...mapGetters(['addresses'])
		},
		onLoad({
			is_choose,
			scene
		}) {
			this.is_choose = is_choose || false;
			this.scene = scene || 'menu';
			uni.$on('refresh-address', this.loadAddress);
			if (!this.addresses.length) {
				this.loadAddress();
			}
		},
		onShareAppMessage(res) {
			let referrer = uni.getStorageSync('referrer');
			console.log('referrer', referrer);
			if (referrer) {
				return {
					title: '恒鲜惠美食在线',
					path: '/pages/menu/menu?referrer=' + referrer,
					imageUrl: require('static/images/menu/banner.jpeg')
				}
			}
		},
		onUnload() {
			uni.$off('refresh-address', this.loadAddress);
		},
		methods: {
			...mapMutations(['SET_ADDRESS', 'SET_ADDRESSES', 'SET_ORDER_TYPE']),
			...mapActions(['addressList', 'addreDelete']),
			loadAddress() {
				uni.showLoading({
					mask: true
				});
				this.addressList().then(res => {
					console.log('address', this.addresses);
					uni.hideLoading();
				});
			},
			add() {
				uni.navigateTo({
					url: '/pages/address/add'
				});
			},
			edit(id) {
				uni.navigateTo({
					url: '/pages/address/add?id=' + id
				});
			},
			handleSwipeClick(id) {
				uni.showModal({
					title: '提示',
					content: '确定要删除？',
					success: res => {
						if (res.confirm) {
							this.addreDelete({
								id
							}).then(res => {
								uni.showToast({
									title: '删除成功！',
									icon: 'success',
									duration: 1000
								});
								setTimeout(() => {
									this.loadAddress();
								}, 1000);
							});
						}
					}
				});
			},
			chooseAddress(address) {
				if (!this.is_choose) return;
				console.log('address', address)
				this.SET_ADDRESS(address);
				this.SET_ORDER_TYPE('takeout');
				if (this.scene == 'menu') {
					uni.switchTab({
						url: '/pages/menu/menu'
					});
				} else if (this.scene == 'pay') {
					uni.navigateTo({
						url: '/pages/pay/pay'
					});
				}
			}
		}
	};
</script>

<style lang="scss" scoped>
	.container {
		width: 100%;
		height: 100%;
	}

	.main {
		width: 100%;
		padding: 30rpx;
		display: flex;
		flex-direction: column;
		padding-bottom: 100rpx;

		.address-wrapper {
			margin-bottom: 30rpx;
		}

		.address {
			width: 100%;
			padding: 40rpx 30rpx;
			background-color: #ffffff;
			display: flex;
			justify-content: space-between;
			align-items: center;

			.left {
				margin-right: 0rpx;

				.font-size-lg {
					.default {
						display: inline-block;
						background: #FB586A;
						color: #fff;
						margin-right: 10rpx;
					}
				}
			}

			.right {
				flex: 1;
				overflow: hidden;
				display: flex;
				flex-direction: column;
			}

			.edit-icon {
				width: 50rpx;
				height: 50rpx;
				flex-shrink: 0;
			}
		}
	}

	.btn-box {
		height: 100rpx;
		background-color: #ffffff;
		box-shadow: 0 0 20rpx rgba($color: $text-color-assist, $alpha: 0.1);
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		padding: 10rpx 0;
		display: flex;
		align-items: center;
		justify-content: center;

		button {
			height: 80rpx;
			width: 80%;
			border-radius: 50rem !important;
			display: flex;
			align-items: center;
			justify-content: center;
		}
	}
</style>
